<template>
  <el-form ref="form" label-width="70px" :model="form" :rules="rules" class="login-container" :inline="true">
    <h3 class="login_title">系统登录</h3>
    <el-form-item label="用户名" prop="username">
        <el-input v-model="form.username" placeholder="请输入账号"></el-input>
    </el-form-item>
    <el-form-item label="密码" prop="password">
        <el-input v-model="form.password" placeholder="请输入密码" type="password"></el-input>
    </el-form-item>
    <el-form-item>
        <el-button style="margin-left: 105px;" @click="submit" type="primary" >登录</el-button>
    </el-form-item>
  </el-form>
</template>

<script>
import Mock from 'mockjs'
import Cookie from 'js-cookie'
import {getMenu} from '../api'

export default {
    name:'Login',
    data(){
        return {
            form:{
                username:'admin',
                password:'admin'
            },
            rules:{
                username:[
                    {required: true, message: '请输入用户名', trigger: 'blur'}
                ],
                password:[
                    {required: true, message: '请输入密码', trigger: 'blur'}
                ]
            }
        }
    },
    methods:{
        submit(){
            // const token = Mock.Random.guid();
            // Cookie.set('token',token)

            this.$refs.form.validate((valid)=>{
                if(valid){
                    getMenu(this.form).then(( {data} )=>{
                        //console.log(data);
                        if(data.code === 20000){
                            Cookie.set('token',data.data.token)
                            this.$router.push('/home')

                            this.$store.commit('SET_MENU',data.data.menu)
                            
                            this.$store.commit('ADD_MENU',this.$router)
                        }else{
                            this.$message.error(data.data.message);
                        }
                    })
                }
            })
            //this.$router.push('/home')
        }
    }
}
</script>

<style lang="less" scoped>
.login-container{
    width: 350px;
    border: 1px solid #eaeaea;
    margin: 180px auto;
    padding: 35px 35px 15px 35px;
    background-color: #fff;
    border-radius: 15px;
    box-shadow: 0 0 25px #cac6c6;
    box-sizing: border-box;
    .login_title{
        text-align: center;
        margin-bottom: 40px;
    }
    .el-input{
        width: 198px;
    }
}
</style>